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(54) Network printer with remote print queue control procedure 

(57) The method of the invention enables remote 
control of a print queue (28) in a network printer (14) 
which receives print jobs over the internet from plural 
client processors (10.12). The network printer (14) 
includes a server procedure (24) which enables transfer 
of files from the network printer (14) over the network 
and a browser procedure (26) which enables retrieval of 
files from client processors (10,12) over the network. 
The method includes the steps of: establishing a queue 
(28) of received print job identifiers; employing the 
server procedure (24) to provide a first file to a client 
processor (10,12) to enable the client processor (10,12) 
to transmit a status request concerning the print queue; 
receiving a message including the status request and 
transmitting, in response, a second file with queue data 
to the client processor (10,12), the second file further 
including queue alteration choices; receiving a 
response message from the client processor (10,12) 
with at least one queue alteration value; and altering the 
queue (28) accordingly. The method further includes the 
step of responding to a received URL from a scanner 
(16), by employing the browser procedure (26) to 
retrieve a text file identified by the URL. 
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Description 

FIELD OF THE INVENTION 

This invention relates to printers that are particu- 
larly adapted to being connected to an Internet port 
and, more particularly, to a network printer which 
includes procedures that enable remote client proces- 
sors to control print jobs that are queued for printing on 
the network printer. 

BACKGROUND OF THE INVENTION 

The Internet and its associated worldwide web 
(WWW) are well-known and established communication 
networks. Increasingly, business applications are 
employing the worldwide web to transfer print jobs from 
client processors to network printers that are remotely 
located. A significant feature of the worldwide web is 
that it offers a common interface which enables comput- 
ing devices that are controlled by different operating 
system platforms to communicate and to be understood 
by each other. This communication capability arises as 
a result of each of the operating system platforms hav- 
ing program modules which enable the devices to com- 
municate via the common messaging protocol used 
over the worldwide web. 

That protocol is termed the "HyperText Transfer 
Protocol" or HTTP. HTTP provides a way for WWW cli- 
ents and servers to communicate, primarily through the 
exchange of messages that are brief and direct. HTTP 
employs specific message categories, i.e.: a "connec- 
tion"; a "request"; a "response" and a "close". A connec- 
tion is a message which occurs as a client tries to 
connect to a specific web server. As will be understood 
from the description below, a network printer which 
incorporates the invention operates as a web server 
and is accessed by client processors. 

A request is when a client processor asks for a web 
resource it is looking for. Such request includes the pro- 
tocol to be used, the name of the object being sought 
(i.e. its universal resource locator or URL), and informa- 
tion about how the server should respond to the client 
processor. 

A response is a server's message which responds 
in the manner requested by the client processor and 
delivers the requested data. A close occurs after the 
information has been transferred in response to the 
request. The connection can then be reopened with 
another request, for example, by clicking on a link in a 
current web page. 

An Internet printing system, recently announced by 
the Pipeline Corporation (see "The Hard-Copy 
Observer", pages 45, 46, March 1997), describes a net- 
work printer that includes functions which enable a URL 
of a print job to be received. The printer's home page 
includes a field that allows a user to enter URLs of 
desired pages to be printed. The printer includes sched- 



uling software which allows a user to program the 
printer to periodically access a prescribed list of web 
sites and to automatically print the pages it finds there. 
The system also enables the printer to be programmed 
5 to retrieve and print pages that are hyperlinked to an 
original document, down a specified number of link lev- 
els. 

Because many client processors can access net- 
work printers over the worldwide web, such a printer 

10 must have an ability to establish a queue for received 
print jobs so as to enable such print jobs to be handled 
in an orderly manner. It is desirable, however, that client 
processors have an ability to view the printer's print 
queue and, to access information regarding the status 

15 of each print job on the print queue. Further it is desira- 
ble that a client processor have an ability, if authorized, 
to alter the print queue. Such a capability will enable the 
print queue to be a "universal queue" that is accessible 
by any number of client processors and will enable each 

20 client processor to render an informed decision regard- 
ing whether it wishes to use the particular network 
printer. Also, the capability will provide an ability to 
remotely modify the print queue, in accordance with 
preassigned priority client queue management rights. 

25 Accordingly, it is an object of this invention to pro- 
vide a network printer with a capability to establish a 
universal print queue. 

It is another object of this invention to provide a net- 
work printer with an ability to report print queue status 

30 data to client processors. 

It is yet another object of this invention to provide a 
network printer with an ability to respond to HTTP -con- 
figured messages and to both report print queue status 
and to retrieve print jobs in response thereto. 

35 It is yet another object of this invention to enable a 
scanner device attached to the WWW to provide a URL 
indicator to a printer and for the printer to respond by 
accessing a scanned image. 

40 SUMMARY OF THE INVENTION 

The method of the invention enables remote control 
of a print queue in a network printer which receives print 
jobs over the Internet from plural client processors. The 

45 network printer includes a server procedure which ena- 
bles transfer of files from the network printer over the 
network and a browser procedure which enables 
retrieval of files from client processors over the network. 
The method includes the steps of: establishing a queue 

so of received print job identifiers; employing the server 
procedure to provide a first file to a client processor to 
enable the client processor to transmit a status request 
concerning the print queue; receiving a message 
including the status request and transmitting, in 

55 response, a second file with queue data to the client 
processor, the second file further including queue alter- 
ation choices; receiving a response message from the 
client processor with at least one queue alteration 
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value; and altering the queue accordingly. The method 
further includes the step of responding to a received 
URL from a scanner, by employing the browser proce- 
dure to retrieve a print job from the scanner that is iden- 
tified by the URL 

BRIEF DESCRIPTION OF THE DRAWINGS 

Fig. 1 is a schematic system diagram illustrating the 
relationship of a printer incorporating the invention to 
plural client processors and a scanner, all of which com- 
municate over the WWW. 

Fig. 2 illustrates a home page provided by the 
printer of Fig. 1 , in response to a message from a client 
processor. 

Fig. 3 is a further printer web page illustrating a 
queue of print jobs awaiting printing in the printer of Fig. 
1. 

Fig. 4 is a further printer web page illustrating job 
detail of any selected job listed in the print queue of Fig. 
3, and further showing various queue alteration actions 
which are available to a client processor. 

DETAILED DESCRIPTION OF THE INVENTION 

Turning to Fig. 1, plural client processors 10, 12... 
etc. are coupled to the WWW and are thus able to com- 
municate with a network printer 14. A scanner 16 is also 
coupled to the WWW and communicates with network 
printer 14. Each dient processor (i.e., 10, 12,...) 
includes a browser procedure 18 and a server proce- 
dure 20. Scanner 16 includes only a server procedure 
20. Further, each client processor includes an applica- 
tion 22 which may have a print job ready for submission 
to printer 14. A client processor (e.g., 12) may wish to 
have a print job 23 that is present in another client proc- 
essor (e.g., 10) submitted to printer 14 for printing. In 
the alternative, a user at a client processor may wish to 
view the status of print jobs queued on printer 14 and to 
alter the queue status of one or more such print jobs. 

Accordingly, printer 14 is also provided with a 
server procedure 24 and a browser procedure 26. 
Server procedure 24 provides a print job management 
function for printer 14 and is further used to respond to 
request messages from one or more client processors. 
Browser procedure 26 enables printer 14 to respond to 
a received URL by accessing, via the WWW, the print 
job designated by the URL. The URL may designate a 
print job residing at any client, whether it is the client 
which originated the message with the URL or any other 
client. The responses transmitted by browser 26 are for- 
matted in a formatter module 30, using the HTML or any 
other formatting procedure. 

Printer 14 further includes a job queue 28 which 
lists the URL's of received print jobs. Upon a URL being 
reached on job queue 28. printer 14 causes browser 26 
to transmit a request to the client processor wherein the 
specific print job corresponding to the URL is located. 



The client processor then responds with the text of the 
print job, which text is then printed by printer 14. 

Job queue 28 is managed by a queue manager 32 
which maintains status data and controls the position of 

5 each of the URLs listed on job queue 28. Queue man- 
ager 32 is further enabled to rearrange the listed URLs 
in accordance with received commands that appear on 
a web page transmitted from a client processor. 

Server procedure 24 maintains a "home page" 

w which is shown in Fig. 2. The home page is the default 
page which is transmitted by server 24 to an inquiring 
client processor that has transmitted a request to printer 
1 4. The home page provides data regarding the proper- 
ties of printer 14, such as its WWW address, capabili- 

15 ties, whether it is on-line, etc.. The home page also 
provides further virtual buttons 40-44 which enable a 
linking to other pages and provide a capability to cause 
the printer to: respond with its properties (button 40); 
come on-line (button 41); provide a listing of jobs that 

20 are present on job queue 28 (button 42) ; provide a diag- 
nostic procedure for remotely diagnosing a problem 
within printer 14 (button 43); and provide further config- 
uration information (button 44). 

Upon receiving the home page from printer 14, a 

25 user at a client processor may wish to view the jobs that 
are presently listed on job queue 28. To obtain a web 
page illustrating the jobs queued on job queue 28, the 
user clicks on job's button 41 which causes a request 
message to be transmitted back to printer 14, with a 

30 code indicating a request to provide the "job's list" page 
shown in Fig. 3. 

The job's list page includes an identifier for each job 
(e.g.. the job's URL); a description of the job; the status 
of the job (i.e., is it printing, printed, queued, etc.) and 

35 the owner of the job. At the bottom of the job's list page 
is a virtual button 50 which enables the user at the client 
processor to access further printer pages. If virtual 
"select job" button 50 is selected by a mouse click and 
then a cursor is placed at a job entry, followed by a 

40 mouse click, a "job detail" page is produced. 

More specifically, upon a user at a client processor 
selecting a particular job in the job's list page, a request 
message is sent to printer 14 which is received by 
server 24. Server 24, in turn, queries queue manager 

45 32 for details of the selected job. A job detail page is 
then constructed, as shown in Fig. 4, with details of the 
selected job. The job detail page is then dispatched as 
a response message to the originating client processor. 
The job detail page enables the originating client 

so processor to exert control over job queue 28 and the 
details of the specific job shown in the received job 
detail page. More specifically, by clicking one of the 
entries on the job detail page, an entry can be high- 
lighted and altered. Thus, as shown in Fig. 4, not only is 

55 the identity of the job indicated, but its state; the number 
of pages printed; the URL of the job; the job description; 
the owner; and the number of copies required. At the 
bottom of the job detail page are a number of virtual but- 
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tons which enable a job entry parameter to be altered. 

Change button 60 enables the alteration of a high- 
lighted field on the page that has been previously 
selected by the user at the client processor. For 
instance, if it is desired to change the number of copies, 
the "copies" line is highlighted, followed by a clicking on 
"change" button 60, after which the number of copies 
can be altered. Change button 60 may also be used to 
modify the queue position of a job listed on job queue 
28. To accomplish such a unilateral change in position, 
the client processor must have been previously pro- 
vided with an assigned priority level which enables its 
print jobs to enjoy a higher priority status than other 
print jobs on job queue 28 that are to be "pushed down" 
in favor of the client processor's print job. In such case, 
change button 60 enables a print job from the higher pri- 
ority client processor to be repositioned on job queue 28 
to a position just prior to a print job of equal or higher pri- 
ority, as the case may be. 

By clicking on "cancel" button 62, a selected job can 
be canceled in its entirety. By clicking on "hold" button 
64, the position on job queue 28 of a selected job will 
not be advanced, notwithstanding the completion of 
jobs higher up on the queue. The clicking of "resume" 
button 66 negates the hold status and enables a contin- 
ued movement of the print job on job queue 28. "Add" 
button 68 enables a message to be sent to printer 1 4 to 
provide a blank "Printer job detail" page, which will ena- 
ble a new job to be entered by the user. 

Buttons 70 and 72 enable messages to be transmit- 
ted to printer 14 to cause a re-transmission of either a 
last transmitted web page or the printer's home page. 

Returning to Fig. 1 . scanner 1 6 is also provided with 
a server procedure 20 which enables scanner 16 to 
transmit a URL of a scanned document text file to a 
printer 14. Such transmission occurs after scanner 16 
has scanned and stored a document and the document 
is now to be printed. Upon receiving the URL. printer 14 
causes browser procedure 26 to transmit a request 
message to scanner 16 which requests that the text file 
be appended to the response message and re-transmit- 
ted back to printer 14. Accordingly, scanner 16 formats 
the response page from printer 14 by appending the 
scanned document text file and transmitting the page 
and text file to printer 14 for printing. Accordingly, printer 
14 executes a file "pull" action upon the data stored in 
scanner 16, thereby enabling the text file to be down- 
loaded to printer 14 and eventually printed. 

While the procedures which control printer 14. i.e., 
server procedure 24, browser procedure 26, formatter 
procedure 30 and print queue manager 32 have been 
described as already having been loaded onto printer 
14, one skilled in the art will realize that such proce- 
dures are initially loaded by insertion of one or more 
memory disks 80 (Fig. 1) into a disk drive read/write 
assembly (not shown) associated with printer 14. 
Accordingly, the invention encompasses not only the 
above-described software procedures when incorpo- 



rated into printer 1 4, but also when such procedures are 
incorporated onto a magnetic disk which is used to con- 
trol various instrumentalities within printer 14. 

It should be understood that the foregoing descrip- 

5 tion is only illustrative of the invention. Various alterna- 
tives and modifications can be devised by those skilled 
in the art without departing from the invention. Accord- 
ingly, the present invention is intended to embrace all 
such alternatives, modifications and variances which fall 

10 within the scope of the appended claims. 

Claims 

1 . A method for enabling control of a network printer 
is (14) which receives print jobs over a network from 

plural client processors (10,12). said network 
printer (14) including a server procedure (24) for 
enabling transfer of files from said network printer 
(14) over said network and a browser procedure 
20 (26) for enabling retrieval of files to said network 
printer (14) over said network, said method com- 
prising the steps of: 

a) establishing a queue (28) of received print 
25 job identifiers; 

b) employing said server procedure (24) to pro- 
vide a first file to a client processor (10,12) to 
enable said client processor (10.12) to transmit 
a status message concerning said queue (28); 

30 c) receiving said status message and enabling 

said server procedure (24) to transmit a 
response comprising a second file with queue 
data to said client processor (10,12). said sec- 
ond file further including queue alteration 

35 choices; and 

d) receiving a further response message from 
said client processor (10,12) with at least one 
queue alteration value and altering said queue 
(28) accordingly. 

40 

2. The method as recited in claim 1. wherein said fur- 
ther response message includes an identifier of a 
print job (23), said method comprising the added 
step of: 

45 

e) employing said browser procedure (26) to 
retrieve said print job (23). 

3. The method as recited in claim 1 , wherein said fur- 
so ther response message comprises a list of print 

jobs on said queue (28) and status indications for 
each said print job. 

4. The method as recited in claim 1 , wherein said sta- 
55 tus indications comprise at least one of: printing 

status, print job owner, order of jobs to print and 
expected time to print. 
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5. The method as recited in claim 1 , wherein said sta- 
tus indications comprise at least one of: printing 
status, print job owner, order of jobs to print and 
expected time to print. 

5 

6. The method as recited in claim 1 , wherein said first 
file and second file are Web pages that are config- 
ured in accordance with a HyperText Markup Lan- 
guage. 

10 

7. The method as recited in claim 1 , wherein said first 
file and second file are each identified by a Univer- 
sal Resource Locator identifier. 

8. The method as recited in claim 1, wherein said is 
server procedure (24) and browser procedure (26) 
operate in accordance with a Hypertext Transfer 
Protocol. 

9. A memory media (80) including procedures for con- 20 
trolling a network printer (14) which receives print 
jobs over a network from plural client processors 
(10,12), said network printer (14) including a server 
procedure (24) for enabling transfer of files from 
said network printer (14) over said network and a 25 
browser procedure (26) for enabling retrieval of files 

to said network printer (14) over said network, said 
memory media (80) comprising: 

a) means for controlling said network printer 30 
(14) to establish a queue (28) of received print 

job identifiers; 

b) means for controlling said network printer 
(14) to employ said server procedure (24) to 
provide a first file to a client processor (10,12) 35 
to enable said client processor (10,12) to trans- 
mit a status message concerning said queue 
(28); 

c) means for controlling said network printer 
(14) to receive said status message and to 40 
enable said server procedure (24) to transmit a 
response comprising a second file with queue 
data to said client processor (10,12), said sec- 
ond file further including queue alteration 
choices; and 45 

d) means for controlling said network printer 
(14) to receive a further response message 
from said client processor (10.12) with at least 
one queue alteration value and to alter said 
queue (28) accordingly. so 

10. The memory media (80) as recited in claim 9, 
wherein said further response message includes 
an identifier of a print job. said memory media (80) 
further comprising: 55 

e) means for controlling said network printer 
(14) to employ said browser procedure (26) to 



8 

retrieve said print job. 

11. The memory media (80) as recited in claim 9, 
wherein said further response message comprises 
a list of print jobs on said queue (28) and status 
indications for each said print job. 

12. The memory media (80) as recited in claim 9, 
wherein said status indications comprise at least 
one of: printing status, print job owner, order of jobs 
to print and expected time to print. 

13. The memory media (80) as recited in claim 9, 
wherein said queue alteration choices for print jobs 
listed on said queue (28) comprise at least one of: 
deleting a print job, reordering a print job, delaying 
a print job, resuming a print job and changing 
attributes of a print job. 

14. The memory media (80) as recited in claim 9, 
wherein said first file and second file are Web 
pages that are configured in accordance with a 
HyperText Markup Language. 

15. The memory media (80) as recited in claim 9, 
wherein said first file and second file are each iden- 
tified by a Universal Resource Locator identifier. 

16. The memory media (80) as recited in claim 9. 
wherein said server procedure (24) and browser 
procedure (26) operate in accordance with a Hyper- 
text Transfer Protocol. 

17. A method for enabling control of a network printer 
(14) which receives print jobs over a network from a 
document scanner (16), said document scanner 
(16) including a server procedure (20) for enabling 
transfer of a Universal Resource Locator (URL) 
over said network . said network printer (14) includ- 
ing a browser procedure (26) for enabling retrieval 
of files to said network printer (14) over said net- 
work, said method comprising the steps of: 

a) Receiving a URL designating a scanned 
document file from said document scanner 
(16); 

b) employing said browser procedure (26) to 
provide a Web page to said document scanner 
(16) to enable said document scanner (16) to 
configure and transmit a response which 
includes said scanned document file; and 

c) receiving said response with said scanned 
document file and printing text from said 
scanned document file. 



EP 0 886 206 A2 



5 



EP 0 886 206 A2 



CLIENT 
PROCESSOR 



UNIX 

SERVER PROCEDURE 

PRINT JOB 



10 



v. 



20 
23 



12 



-80 



PRINTER 



SERVER 
(HTTP) 



I 



SCANNER 
SERVER PROCEDURE 



CIIFNT PROCESSOR 








APPLICATION 
(PRINT JOB) 




BROWSER 
(HTTP) 


SERVER 
(HTTP) 


^-20 

(WINDOWS) 





-24 



JOB QUEUE 



28 



WWW 



-14 



QUEUE 
MANAGER 



BROWSER 
(HTTP) 



-16 
-20 



32 



26 



-30 



FORMATTER 
(HTML) 



FIG.1 



EP 0 886 206 A2 



PRINTER HOME PAGE 



PRINTER TYPE: 
ADDRESS: 

CAPABILITIES: 
ppm: 

CONTRA LANGUAGE: 
MEMORY: 



FIG.2 




ONLINE 



JOBS 



DIAGNOSTIC 



CONFIG. 



41 



42 



-43 



44 



PRINTER JOBS LIST 



JD 
10 
11 

15 
20 



DESCRIPTION 
SPREAD SHEET 
LETTER 
DOCUMENT X 
DOCUMENT Y 



STATUS 

PRINTED 

PRINTING 

QUEUED 

QUEUED 



OWNER 

STEVE 

JEFF 

SAM 

ROB 




FIG.3 



7 



EP 0 886 206 A2 



PRINTER JOB DETAIL 



JOB: 15 

STATUS: QUEUED 

QUEUE POSITION: #3 

PAGES PRINTED: NONE 

URL: http: // ins / default: htm 

JOB DESCRIPTION: DOCUMENT X 

OWNER: SAM 

COPIES: 2 



60 



CHANGE 



62 



CANCEL 



64 



HOLD 



66 



RESUME 



68 



ADD 



RETURN 


TO 


LAST 


PAGE 




RETURN 


TO 


HOME 


PAGE 



70 



72 



FIG.4 



8 



